// 评论发布的弹窗口
<template>
  <div class="comment-post">
    <van-field
      class="post-field"
      v-model.trim="message"
      rows="2"
      autosize
      type="textarea"
      maxlength="50"
      placeholder="请输入留言"
      show-word-limit
    />
    <van-button
      class="post-btn"
      @click="onPost"
      :disabled = '!message.length'
    >发布</van-button>
  </div>
</template>

<script>
import{addComment} from '@/api/comment'
export default {
  name: 'CommentPost',
  components: {},
  inject:{
     articleId:{
       type:[Number,String,Object],
     default:null
     }
  },
  props: {
      target:{
          type:[Number,String,Object],
          required:true
      }
  },
  data () {
    return {
      message: ''
    }
  },
  computed: {},
  watch: {},
  created () {},
  mounted () {},
  methods: {
      async onPost(){
           // 在组件中必须通过this.$toast 来调用Toast
     this.$toast.loading({
        message: '发布中...',
        forbidClick: true, // 禁用背景点击
        duration: 0 // 持续时间，默认 2000，0 表示持续展示不关闭
      })
          try {
              const {data}  = await addComment({
                  target:this.target.toString(),// 评论的目标id（评论文章即为文章id，对评论进行回复则为评论id）
                  content:this.message,// 评论内容
                  art_id:this.articleId ? this.articleId.toString() : null// 文章id，对评论内容发表回复时，需要传递此参数，表明所属文章id。对文章进行评论，不要传此参数。
              })
            //   console.log(data);
            // 关闭弹出层
            // 将发布的内容放到顶部
            // 清空文本框
            this.message = ''
            this.$emit('post-success',data.data)
            this.$toast.success('发布成功')
          } catch (error) {
            console.log(error);
              this.$toast.fail('评论失败')
          }
      }
  }
}
</script>

<style scoped lang="less">
.comment-post {
  display: flex;
  align-items: center;
  padding: 32px 0 32px 32px;
  .post-field {
    background-color: #f5f7f9;
  }
  .post-btn {
    width: 150px;
    border: none;
    padding: 0;
    color: #6ba3d8;
    &::before {
      display: none;
    }
  }
}
</style>
